草庐IT

sql - 按属性值过滤 XML 查询

全部标签

ruby - 如何为名称以问号结尾的属性定义 setter?

我正在尝试添加一个名为“已启用?”的属性吗?到同时具有getter和setter的模型。但是,当我执行以下操作时:defenabled?=value#..logicgoeshere..end我收到语法错误,意外的“?”,需要“\n”或“;”我应该怎么做? 最佳答案 是的,ruby语法只允许?在方法名称中,如果它是最后一个字符,所以foo?=是无效的。您可以做的一件事是定义enabled?、enable和disable(或enable!和disable!如果你想强调它们是变异方法)。如果这不符合您的需求,您可以只将方法命名为enabl

sql - 不同的加入 Rails

视频有很多事件我正在尝试获取所有在未来安排了事件的视频。我已经有了这个:named_scope:scheduled_in_future,:joins=>:event,:conditions=>["event.scheduled_start>?ANDevent.status=?",Time.now.to_i,'PENDING']这行得通,但如果同一个视频在未来有多个事件,它会给我重复的视频记录。当然,我可以遍历数组并清除重复项,但必须有一种SQL方法才能做到这一点。我尝试添加一个:select=>"DISTINCT(video.id)"但它只返回ID字段而不是整个记录。

sql - 如何使用 Arel 正确地向带有 'or' 和 'and' 子句的 SQL 查询添加括号?

我正在使用RubyonRails3.2.2,我想生成以下SQL查询:SELECT`articles`.*FROM`articles`WHERE(`articles`.`user_id`=1OR`articles`.`status`='published'OR(`articles`.`status`='temp'AND`articles`.`user_id`IN(10,11,12,)))通过使用Arel这样Article.where(arel_table[:user_id].eq(1).or(arel_table[:status].eq("published")).or(arel_tab

sql - Rails 3 Sum 两个领域的产品

我需要计算我的Rails3应用中两个字段的乘积之和(即相当于Excel的sumproduct函数)。Rails中是否有一种方法可以帮助解决这个问题?如果没有,那么使用自定义sql的Rails代码是什么?例如,酒店有很多房间。房间具有sqft(平方英尺)、数量(该尺寸)和hotel_id的属性。我想计算给定酒店中所有房间的总平方英尺。在SQL中,对于Hotel.id=8,我相信以下语句会起作用:selectsum(rooms.sqft*rooms.quantity)asSumSqftfromroomsinnerjoinhotelsonrooms.hotel_id=hotels.idwhe

ruby-on-rails - 如何在 Rails Controller 操作的 RSpec 测试中指定查询字符串?

我有一个名为yearly_csv的操作。在此操作中,我执行两个操作,如需求和供应。defyearly_csvifdemand=='true'demand_csvelsesupply_csvendend我的View中有两个单选按钮来选择其中一个操作。现在我想在RSpec中单独测试每个操作。例如,一个供应规范和另一个需求规范。我的问题是如何将单选按钮值传递给yearly_csv操作(get)? 最佳答案 在RSpec的较新版本中,您必须使用params键声明查询字符串参数:get:yearly_csv,params:{demand:'t

ruby-on-rails - 构建一个 Rails 表单来过滤索引页面?

大家好,我在过滤系统中数千个贸易项目的展示时遇到了问题。根据我们正在构建的系统的规范,我们必须有一个表格,允许人们输入开始日期,然后输入以分钟为单位的间隔,以过滤项目的显示。我已经构建了我的辅助函数来返回该间隔期间内的所有交易,但我无法终生正确构建将在索引页顶部返回日期时间值和整数值的表单?有什么想法吗?我是否必须构建一个单独的模型对象来为其赋值,还是有更简单的方法? 最佳答案 在您的索引页面上,您可以像这样创建一个过滤器表单:getdo%>然后您的表单将使用查询字符串参数在您的页面上执行GET,然后您可以在您的Controller

sql - 在 Rails 中进行计数的正确方法是什么?

我有一个包含以下许多代码片段的Rails应用程序:Ouractivecommunityof我的问题是,这是计算观看次数的正确方法吗?看起来很“肮脏”,有没有更粗鲁的方法来计算?我可能在考虑命名范围,但我只是想确保这些类型的东西不会对性能产生更大的影响。谢谢你, 最佳答案 您不需要名称范围来执行计数。Account.where(:admin=>false).count但是命名作用域是使您的代码更具可重用性的绝佳方式。命名范围不会对您的应用程序产生任何明显的性能影响。 关于sql-在Rail

ruby-on-rails - 如何在不使用不同变量名的情况下更新 Rails 模型中实例方法中的属性?

我想在rails的实例方法中更新属性,而不必被迫更改传入的参数,这样我就可以利用rails的自动属性。这是一个例子。理想:status="some_new_status"person.update(status)classPerson我现在要做的:classPerson我明白在这个例子中这并不重要。但是,当我有复杂的更新方法时,如果我可以删除其中的一些代码,它会更清晰。 最佳答案 你应该使用内置的Rails方法:@person.update_attribute(:status,"SomeValue")#nocallbacktrigg

ruby-on-rails - 如何逐行递增地构建 ActiveRecord 查询?

我想使用运行时数据拼凑一个ActiveRecord查询。我的想法是……r=Person.where('last_nameLIKE?',foo)r.where('created_at但这并没有按预期工作。要使其正常工作,您必须将它们全部链接在一条线上...Person.where('last_nameLIKE?',foo)\.where('created_at我正在尝试找出一种方法将其分散到多行的单独操作中。 最佳答案 QueryInterface方法(如.where)返回一个新对象。所以你只需要坚持下去。见:r=Person.whe

ruby - 在 Ruby 中使用单引号和双引号查询哈希有什么区别?

{"user"=>{"bio"=>"rubyist","created_at"=>"2011-05-03T15:21:46+02:00","email"=>"paul@pauldix.net","id"=>61,"name"=>"paul","updated_at"=>"2011-05-03T15:21:46+02:00"}}使用双引号和单引号有什么区别?:attributes=JSON.parse(last_response.body)["user"]attributes=JSON.parse(last_response.body)['user']第一种情况好像可以,但是第二种情况没